IN THE CLAIMS: 



Please amend the claims as shown below. 

1 . (Currently amended) A system for controlling co-scheduling of processes in a 
computer comprising at least one process and a spin daemon, the at least one process being 
configured to, when it is waiting for a flag to change condition, transmit a flag monitor 
request to the spin daemon and de-schedule itself, the spin daemon being configured to, 
after receiving [a] ttie flag monitor request monitor the flag and, after the flag changes 
condition, enable the at least one process to be re-scheduled for execution by the computer. 

2. (Original) A system as defined in claim 1 in which said spin daemon is configured to 
monitor a pluraUty of flags, each in response to a flag monitor request, the spin daemon 
maintaining a list identifying those flags it is to monitor, the spin daemon being fiirther 
configured to, when it receives a flag monitor request, add an identification of a flag 
associated with the request to the fist. 

3. (Original) A system as defined in claim 2 in which said flags are contained in a 
memory segment, the spin daemon being configured to enable the at least one process to be 
re-scheduled following a change of condition of any flag in said memory segment. 

4. (Currently amended) A system as defined in claim [1] 3 in which said at least one 
process is configured to register with said spin daemon, during registration the at least one 
process being configured to provide the spin daemon with an identifier for the memory 
segment, the spin daemon being configured to provide a handle, the at least one process 
being configured to use the handle in the flag monitor request. 

5. (Original) A system as defined in claim 1 in which said at least one process and 
said spin daemon are configured to communicate over a socket. 
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6. (Currently amended) A method of controlling co-scheduling of processes in a 
computer comprising at least one process and a spin daemon, the method comprising the steps 
of: 

A. enabling the at least one process to, when it is waiting for a flag to 
change condition, transmit a flag monitor request to the spin daemon and de- 
schedule itself, 

B . enabling the spin daemon to, after receiving [a] tfie flag monitor request 
monitor the flag and, after the flag changes condition, enable the at least one 
process to be re-scheduled for execution by the computer. 

7. (Original) A method as defined in claim 6, the spin daemon being configured to 
monitor a plurality of flags, each in response to a flag monitor request, the spin daemon 
maintaining a list identifying those flags it is to monitor, the method including the step of 
enabling the spin daemon being to, when it receives a flag monitor request, add an 
identification of a flag associated with the request to the list. 

8. (Original) A method as defined in claim 7 in which said flags are contained in a 
memory segment, the method including the step of enabling the spin daemon to enable the at 
least one process to be re-scheduled following a change of condition of any flag in said 
memory segment. 

9. (Currenfly amended) A method as defined in claim [6] 8 fiirther including the steps 
of 

A enabling the at least one process to register with said spin daemon, during 
registration the at least one process being configured to provide the spin 
daemon with an identifier for the memory segment; and 

B. enabling the spin daemon to provide a handle for use by the at least one 
process in the flag monitor request. 

1 0. (Original) A method as defined in claim 6 further comprising the step of enabling the at 
least one process and said spin daemon communicate over a socket. 



3 



1 1 . (Currently amended) A computer program product for use in connection with a 
computer to control co-scheduling of at least one process in the computer, the computer 
program product including a computer readable medium having encoded thereon: 

A. a process module configured to enable the computer to, when the at least one 
process is waiting for a flag to change condition, transmit a flag monitor 
request to th e spin da e mon and de-schedule itself, 

B. a spin daemon module configured to enable the computer to, after 
receiving [a] flie flag monitor request^ monitor the flag and, after the flag 
changes condition, enable the at least one process to be re-scheduled for 
execution by the computer. 

1 2. (Original) A computer program product as defined in claim 1 1 in which said spin 
daemon is configured to enable the computer to monitor a plurality of flags, each in response 
to a flag monitor request, the spin daemon enabling the computer to maintain a list identifying 
those flags it is to monitor, the spin daemon being fiuther configured to enable the computer 
to, when it receives a flag monitor request, add an identification of a flag associated with the 
request to the list. 

13. (Original) A computer program product as defiined in claim 12 in which said 
flags are contained in a memory segment, the spin daemon being configured to enable the 
computer enable the at least one process to be re-scheduled following a change of condition 
of any flag in said memory segment. 

14. (Currently Amended) A computer program product as defined in claim [11] B in 
which said at least one process is configured to enable the computer to register with said 
spin daemon, during registration the at least one process being configured to enable the 
computer to provide the spin daemon with an identifier for the memory segment, the spin 
daemon being configured to enable the computer to provide a handle, the at least one process 
being configured to use the handle in the flag monitor request. 
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15. (Original) A computer program product as defined in claim 1 1 in which said at least 
one process and said spin daemon are configured to enable the computer to communicate over 
a socket. 
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